草庐IT

Python selenium 测试卡在 urlopen 中

全部标签

python - Golang单元测试python函数

我在Golang中有一个调用python函数的API处理程序。我如何模拟来自python函数的响应以避免依赖该函数正确运行来测试Golang函数? 最佳答案 您可以将您的函数包装到一个新的moc函数中:funcCallPythonFunctionMoc()Result{varresResultvarerrerrorres,err=CallPythonFunction()iferr!=nil{res="Mocvalue"}returnres编辑:如果您实际上不想调用python函数,只需返回moc值:funcCallPythonFun

go - 在 go 中测试连接到 db 的处理程序

我有一个连接到数据库并检索记录的处理程序。我为此写了一个测试用例,它是这样的:main_test.gopackagemainimport("os""fmt""testing""net/http""net/http/httptest")varaAppfuncTestMain(m*testing.M){a=App{}a.InitializeDB(fmt.Sprintf("postgres://****:****@localhost/db?sslmode=disable"))code:=m.Run()os.Exit(code)}funcTestRulesetGet(t*testing.T){

mysql - 如何测试使用数据库(mysql)的 Go 代码?

我有一个使用MySQL的gRPC服务,需要在每个测试用例后清除记录。我尝试用事务来包装每个测试用例。如果我的rpc代码中没有事务,它就可以工作,但如果有,它就会失败。并且会出现如下错误:can'tstarttransaction...sql:Transactionhasalreadybeencommittedorrolledback然后我尝试使用truncate来清除记录,但一些测试用例随机失败。我的代码是这样的(我使用gorm):funcfoo(db*gorm.DB){tx:=db.Begin()//queryandinserttx.Commit()}//Usetransaction

go - 如何测试 Gin 应用程序中的主要功能?

如何测试funcmain?像这样:funcmain(){Engine:=GetEngine()//returnsginrouterwithhandlersatttachedEngine.Run(":8080")}它只有2行,但我想将它们覆盖。TestMain'是为测试准备保留的,这是否意味着测试main不是语言创建者计划的?我可以将内容移动到另一个函数mainReal但它似乎有些过度工程?如何测试gin是否启动良好?我可以在单独的goroutine中启动main,检查回复并停止它吗?谢谢。附言可能的重复不是精确的重复,因为它不是致力于测试funcmain()本身,而是致力于向外移动的想

unit-testing - 在 go 中正确测试 http 路由

我有5个端点,它们具有GET、POST和DELETE等方法来测试。我使用go的内置测试包编写了测试用例。我担心我遗漏了一些我不感兴趣的案例。我已经在代码审查中发布了我的测试用例进行审查,但我没有得到任何回应。我也关注了这个帖子TestingHTTProutesingolang.所有这些测试用例都在检查响应代码。问题是,我的大部分测试用例都遵循类似的模式,我以不同的格式发布数据并检查响应代码。我强烈觉得我错过了一些东西,当我将它推向产品时会破坏我的API。我需要对测试这些路由有一些了解,这样我才能有信心将API推向产品。main_test.gofuncTestSigHandler(t*t

function - Golang 函数测试

我正在使用第三方库,它是一些C函数的包装器。不幸的是,几乎所有的Go函数都是免费的(它们没有接收器,它们不是方法);不是我会采用的设计方法,但它就是我所拥有的。仅使用Go的标准“测试”库:是否有一种解决方案允许我创建可以模拟函数的测试?或者是将库包装成结构和接口(interface),然后模拟接口(interface)来实现我的目标的解决方案?我创建了一个蒙特卡洛模拟,它也处理生成的数据集。我的一种评估算法会寻找特定模型,然后将其传递给第三方函数进行评估。我知道我的边缘情况并且知道调用计数应该是多少,这就是我想要测试的。也许只需要一个简单的计数器?我发现使用这个库的其他项目没有完全覆盖

Go - 集成测试使用测试数据库连接

go程序使用连接字符串连接到数据库。目前该连接字符串存储在环境变量中。我的挑战是编写一个自动化测试,针对测试数据库运行程序。我想我会在测试的init()函数中设置连接字符串环境变量,但是在测试init()之前调用了主程序的init()函数,所以这不起作用。解决方法似乎是将连接字符串默认为测试数据库。如果没有定义环境变量,则使用test;如果已定义(生产),则改用它。有替代方案吗?有没有更好的方法? 最佳答案 我目前的解决方案是使连接成为未初始化的全局连接。该函数检查连接是否为nil-如果是,则将其初始化。该测试有一个setup()函

go - pprof 配置文件与 julienschmidtrouter 和基准测试不分析处理程序

我正在尝试分析我编写的Web服务器,但我的pprof不包含有关处理程序函数的任何数据。我正在使用httprouterpackage由julienschmidt编写,并想简单地对我的一个处理程序进行基准测试,然后查看pprof配置文件。对于基准测试,我使用go-wrk我像这样设置我的网络服务器和pprof://Configuretheserverserver:=&http.Server{Addr:":4000",Handler:router,}gofunc(){log.Println(http.ListenAndServe(":6060",nil))}()//Starttheserver

testing - 测试 Go 中未导出函数的命名约定

我无法追溯我是从哪里知道的,但通常情况下,如果有人为方法Foo编写测试,则相应的测试名为TestFoo。如果测试一个未导出的函数,比如foo,那么测试的名称应该是什么?我的问题来自这样一个事实,当要求为未导出的函数生成测试时,JetBrainsIDEforGo会生成类似Test_foo的内容。这种行为可能是有道理的,因为如果你有Foo并且它是未导出的counterpatfoo在同一个包中,你会想以某种方式对它们进行不同的测试(在至少对于IDE中的跳转测试功能而言)。那么在未导出的函数之后命名测试有什么约定吗?顺便说一句:Go的文档testing包说,如果是,则执行测试:anyfunct

go - 将数据库凭据传递给测试?

我尝试了几种方法(如下所示),但我都不喜欢其中任何一种。所以我决定询问社区是否有更好的方法。方法一将数据库凭据作为参数传递:gotest-args-db_user=test-db_pass=secret然后在测试中使用它:packagemy_testvardbUser=flag.String("db_user","","testdatabaseuser")vardbPass=flag.String("db_pass","","testdatabasepassword")funcTestSomething(t*testing.T){db:=open(*dbUser,*dbPass)}方法